JavaScript 模块化编程

网站越来越复杂,js代码、js文件也越来越多,会遇到什么问题?

1.命名冲突

2.文件依赖问题

什么是模块化

模块化开发演变

全局函数

  • 命名冲突
  • 文件依赖的问题

    对象封装

  • 用命名空间的方式进行封装
  • 先约定命名的规范的形式
  • 对象里面的属性和方法很容易被修改掉,很不安全

划分私有空间

-通过匿名函数自执行的方法封装模块,
-可以保护私有变量和方法

模块的维护扩展

  • 开闭原则,对修改关闭,对扩展开放。
  • 增加了代码的健壮性和容错性

模块的第三方依赖

  • 模块职责唯一性
  • 把依赖的模块,通过依赖注入的形式,在你的参数上进行体现。

总结

  • 最大的问题,规范的问题
  • 如果在多人协作开发过程中,会有很大的问题
  • 多人协作开发过程中:代码的风格一定要统一

模块化规范

服务器端模块化规范

浏览器端模块化规范

  • AMD
    • RequireJS
  • CMD
    • SeaJS
      commonjs
      • node.js

SeaJS

基本使用

整体感知

定义模块 define

  • 定义模块 define(function(){})
  • 函数体内的方法属性都属于这个方法,对外有封装性;解决了命名冲突问题,使js代码有了封装性
  • 直接调用 jQuery 插件等非标准模块的方法 http://my.oschina.net/briviowang/blog/208587

启动模块 seajs.use

  • 加载入口模块,我们把define定义的js就叫模块
  • 这个用于在html代码里面的加载

    加载模块 require

    -加载文件依赖、模块依赖的,用于define函数体内

    暴露接口 exports 和 module.exports

  • module.exports曝露出一个完整的对象,只能扔一次只能曝露出来一个
  • exports是module.exports的别名,可以用来单个属性、方法、对象的曝露,用.的形式,exports能做的事情module.exports也可以做
  • 使用场景用.属性的形式曝露属性和方法的时候,而且是多个的时候用exports
  • module.exports直接等于的方式用,直接等于一个方法属性对象等等~~~
    ##requirejs
    与seajs的区别
    requirejs是优先加载的
    seajs是懒加载的,就是有拖延症,用的时候才加载
    http://www.requirejs.cn/
Share